# RUN: llc -mtriple=ppc64-- -run-pass scavenger-test -verify-machineinstrs -o - %s | FileCheck %s
---
# CHECK-LABEL: name: noscav0
name: noscav0
tracksRegLiveness: true
body: |
  bb.0:
    ; CHECK: [[REG0:\$r[0-9]+]] = LI 42
    ; CHECK-NEXT: NOP implicit killed [[REG0]]
    %0 : gprc = LI 42
    NOP implicit %0

    ; CHECK: [[REG1:\$r[0-9]+]] = LI 42
    ; CHECK-NEXT: NOP
    ; CHECK-NEXT: NOP implicit [[REG1]]
    ; CHECK-NEXT: NOP
    ; CHECK-NEXT: NOP implicit killed [[REG1]]
    %1 : gprc = LI 42
    NOP
    NOP implicit %1
    NOP
    NOP implicit %1

    ; CHECK: [[REG2:\$r[0-9]+]] = LI 42
    ; CHECK-NEXT: NOP implicit [[REG2]]
    %2 : gprc = LI 42
    NOP implicit %2

    $x0 = IMPLICIT_DEF
    $x1 = IMPLICIT_DEF
    $x2 = IMPLICIT_DEF
    $x3 = IMPLICIT_DEF
    $x4 = IMPLICIT_DEF
    $x27 = IMPLICIT_DEF
    $x28 = IMPLICIT_DEF
    $x29 = IMPLICIT_DEF
    $x30 = IMPLICIT_DEF

    ; CHECK-NOT: $x0 = LI 42
    ; CHECK-NOT: $x1 = LI 42
    ; CHECK-NOT: $x2 = LI 42
    ; CHECK-NOT: $x3 = LI 42
    ; CHECK-NOT: $x4 = LI 42
    ; CHECK-NOT: $x5 = LI 42
    ; CHECK-NOT: $x27 = LI 42
    ; CHECK-NOT: $x28 = LI 42
    ; CHECK-NOT: $x29 = LI 42
    ; CHECK-NOT: $x30 = LI 42
    ; CHECK: [[REG3:\$r[0-9]+]] = LI 42
    ; CHECK-NEXT: $x5 = IMPLICIT_DEF
    ; CHECK-NEXT: NOP implicit killed [[REG2]]
    ; CHECK-NEXT: NOP implicit killed [[REG3]]
    %3 : gprc = LI 42
    $x5 = IMPLICIT_DEF
    NOP implicit %2
    NOP implicit %3

    NOP implicit $x0
    NOP implicit $x1
    NOP implicit $x2
    NOP implicit $x3
    NOP implicit $x4
    NOP implicit $x5
    NOP implicit $x27
    NOP implicit $x28
    NOP implicit $x29
    NOP implicit $x30
...
---
# CHECK-LABEL: name: scav0
name: scav0
tracksRegLiveness: true
stack:
  # variable-sized object should be a reason to reserve an emergency spillslot
  # in the RegScavenger
  - { id: 0, type: variable-sized, offset: -32, alignment: 1 }
body: |
  bb.0:
    $x0 = IMPLICIT_DEF
    $x1 = IMPLICIT_DEF
    $x2 = IMPLICIT_DEF
    $x3 = IMPLICIT_DEF
    $x4 = IMPLICIT_DEF
    $x5 = IMPLICIT_DEF
    $x6 = IMPLICIT_DEF
    $x7 = IMPLICIT_DEF
    $x8 = IMPLICIT_DEF
    $x9 = IMPLICIT_DEF
    $x10 = IMPLICIT_DEF
    $x11 = IMPLICIT_DEF
    $x12 = IMPLICIT_DEF
    $x13 = IMPLICIT_DEF
    $x14 = IMPLICIT_DEF
    $x15 = IMPLICIT_DEF
    $x16 = IMPLICIT_DEF
    $x17 = IMPLICIT_DEF
    $x18 = IMPLICIT_DEF
    $x19 = IMPLICIT_DEF
    $x20 = IMPLICIT_DEF
    $x21 = IMPLICIT_DEF
    $x22 = IMPLICIT_DEF
    $x23 = IMPLICIT_DEF
    $x24 = IMPLICIT_DEF
    $x25 = IMPLICIT_DEF
    $x26 = IMPLICIT_DEF
    $x27 = IMPLICIT_DEF
    $x28 = IMPLICIT_DEF
    $x29 = IMPLICIT_DEF
    $x30 = IMPLICIT_DEF

    ; CHECK: STD killed [[SPILLEDREG:\$x[0-9]+]]
    ; CHECK: [[SPILLEDREG]] = LI8 42
    ; CHECK: NOP implicit killed [[SPILLEDREG]]
    ; CHECK: [[SPILLEDREG]] = LD
    %0 : g8rc = LI8 42
    NOP implicit %0

    NOP implicit $x0
    NOP implicit $x1
    NOP implicit $x2
    NOP implicit $x3
    NOP implicit $x4
    NOP implicit $x5
    NOP implicit $x6
    NOP implicit $x7
    NOP implicit $x8
    NOP implicit $x9
    NOP implicit $x10
    NOP implicit $x11
    NOP implicit $x12
    NOP implicit $x13
    NOP implicit $x14
    NOP implicit $x15
    NOP implicit $x16
    NOP implicit $x17
    NOP implicit $x18
    NOP implicit $x19
    NOP implicit $x20
    NOP implicit $x21
    NOP implicit $x22
    NOP implicit $x23
    NOP implicit $x24
    NOP implicit $x25
    NOP implicit $x26
    NOP implicit $x27
    NOP implicit $x28
    NOP implicit $x29
    NOP implicit $x30
...
---
# Check for bug where we would refuse to spill before the first instruction in a
# block.
# CHECK-LABEL: name: spill_at_begin
# CHECK: bb.0:
# CHECK: liveins:
# CHECK: STD killed [[REG:\$x[0-9]+]]{{.*}}(store (s64) into %stack.{{[0-9]+}})
# CHECK: [[REG]] = LIS8 0
# CHECK: [[REG]] = ORI8 killed [[REG]], 48
# CHECK: NOP implicit killed [[REG]]
# CHECK: [[REG]] = LD{{.*}}(load (s64) from %stack.{{[0-9]+}})
name: spill_at_begin
tracksRegLiveness: true
stack:
  # variable-sized object should be a reason to reserve an emergency spillslot
  # in the RegScavenger
  - { id: 0, type: variable-sized, offset: -32, alignment: 1 }
body: |
  bb.0:
    liveins: $x0, $x1, $x2, $x3, $x4, $x5, $x6, $x7, $x8, $x9, $x10, $x11, $x12, $x13, $x14, $x15, $x16, $x17, $x18, $x19, $x20, $x21, $x22, $x23, $x24, $x25, $x26, $x27, $x28, $x29, $x30, $x31
    %0 : g8rc = LIS8 0
    %1 : g8rc = ORI8 %0, 48
    NOP implicit %1

    NOP implicit $x0
    NOP implicit $x1
    NOP implicit $x2
    NOP implicit $x3
    NOP implicit $x4
    NOP implicit $x5
    NOP implicit $x6
    NOP implicit $x7
    NOP implicit $x8
    NOP implicit $x9
    NOP implicit $x10
    NOP implicit $x11
    NOP implicit $x12
    NOP implicit $x13
    NOP implicit $x14
    NOP implicit $x15
    NOP implicit $x16
    NOP implicit $x17
    NOP implicit $x18
    NOP implicit $x19
    NOP implicit $x20
    NOP implicit $x21
    NOP implicit $x22
    NOP implicit $x23
    NOP implicit $x24
    NOP implicit $x25
    NOP implicit $x26
    NOP implicit $x27
    NOP implicit $x28
    NOP implicit $x29
    NOP implicit $x30
    NOP implicit $x31
...
